#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
const int MAXN=550;
int a[MAXN];
int b[MAXN];
int t;
int al;
int bl;
int dp[MAXN];
int main(void){
    scanf("%d",&t);
    while(t--){
        memset(a,0,sizeof(a));
        memset(b,0,sizeof(b));
        scanf("%d",&al);
        for(int i=1;i<=al;i++){
            scanf("%d",&a[i]);
        }
        scanf("%d",&bl);
        for(int i=1;i<=bl;i++){
            scanf("%d",&b[i]);
        }
        memset(dp,0,sizeof(dp));
        int ans=0;
        for(int i=1;i<=al;i++){
            int len=0;
            for(int j=1;j<=bl;j++){
                if(a[i]>b[j]){
                    len=max(len,dp[j]);
                }
                else if(a[i]==b[j]){
                    dp[j]=max(dp[j],len+1);
                }
                ans=max(ans,dp[j]);
            }
        }
        printf("%d\n",ans);
        if(t!=0){
            printf("\n");
        }
    }
    return 0;
}